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RADIO FREQUENCY IDENTIFICATION METHOD AND SYSTEM 
OF DISTRIBUTING PRODUCTS 

BACKGROUND OF THE INVENTION 

The present invention relates to methods and systems for distributing products 
to customers. More particularly, the invention relates to a method and system that 
tracks the use of products using radio frequency tags and provides information to a 
central computer to enable automated restocking, inventory, tracking, or reordering of 
5 the products. 

The Internet, EDI, and similar systems permit businesses and ordinary 
consumers to order goods. However, the delivery of those goods still depends on 
distribution systems that are based in the physical world. The science-fiction ideal of 
being able to instantly have goods pop out of a computer or to receive them through a 

10 "transporter" or some other device" has not yet been realized, and probably will not for 
many, many years. Presently, consumers may have goods shipped via various 
overnight delivery services. One drawback of present delivery technology is that it is 
primarily paper-based. Orders are made on paper and delivery involves shipping 
invoices, receipts, and other paperwork, which is costly to handle and annoying to 

1 5 many people. Even with technology that is not paper-based, ordering and receiving 
goods requires a number of steps. For example, for a typical Internet order, a 
consumer must view the applicable Web site, select the item, such as by clicking on 
an icon, fill out an electronic order form, and wait for the product to be delivered. 
Regardless of whether paper-based or electronic technology is used, present delivery 

20 methods visually require that the customer or his or her agent be present at a physical 
location to take the delivery of the ordered product. Further, delivery is usually made 
to a loading dock or similar location. This requires some internal distribution system 
to deliver the goods from the initial delivery point to the location where it is actually 
needed. 
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SUMMARY OF THE INVENTION 

Accordingly, there is a need to improve the distribution of goods so that 
consumers experience distribution of goods at a location proximate to where the 
consumer will use the goods without requiring paper or computer ordering. There is 
also a need for a distribution system that requires less user intervention and data input 
5 than existing systems. 

The invention provides a system and method where a user need only find the 
product of interest and take that product. As compared to most Internet-based 
systems and methods, the invention is "clickless." In other words, the invention 
requires little or no manual input from users. The invention provides a system for 

10 distributing a plurality of products. Each of the products has a radio frequency ("RF") 
tag. As used herein, radio frequency means electromagnetic radiation that lies 
between audible and infrared radiation. Each tag is encoded with a unique identifying 
code. In one embodiment, the system is designed to be accessed by individuals 
possessing a radio frequency user badge with an identifying code. Alternatively, the 

1 5 system could rely on magnetic swipe cards, password systems, biometric devices 

(such as a retinal scanner, thumbprint reader, voice identification unit, or the like), or 
other systems for lirmting access to authorized individuals. 

The system includes one or more cabinets, refrigerators, similar storage units, 
(generically referred to as "micro-warehouses") or even secured rooms that are 

20 stocked with the RF tagged products and accessed by individuals through one of the 
mechanisms described above. In one embodiment, each micro-warehouse has a door 
that may be equipped with a lock (such as an electric actuated lock), an antenna or 
antenna array mounted on or in the micro-warehouse, a client controller coupled to 
the lock and the antenna, and an output device such as a light or display. Using a 

25 signal from the antenna or other input device, the client controller checks the identity 
of the individual accessing the micro-warehouse, such as by reading the code of the 
user badge. The output device is then activated to indicate whether the individual 
attempting to access the micro-warehouse is authorized to access the unit. If the code 
or other identifier matches stored records of authorized users, the client controller 
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opens the door and the user may remove desired products from the micro-warehouse. 
Once the user closes the door, the client controller performs a scan of the products 
remaining in the micro-warehouse to determine the identity of each of the products. 
The client controller then generates a message including the identity of each of the 
5 products or other message related to the products taken, and sends that message to a 
server. The server tracks product and user information automatically, that is, without 
relying on user input. In particular, the server tracks product inventory, customer 
usage, restocking, usage frequency, faults, micro-warehouse temperature, timing, and 
other information. The server also generates orders for products taken from the 
1 0 micro-warehouse by the user. The server can be programmed to automatically place 
those orders, with the result that the system is "clickless." That is, the system 
eliminates the need for the customer to re-order consumed items. 

In addition to the features noted above, the system may also locate the position 
or presence of one or more specific products in a micro-warehouse by conducting a 

15 scan of the micro-warehouse. In this way, the system can sense a disordered state of 
the product in the micro-warehouse. For example, the system can detect whether all 
of the components in a kit product are in the relevant kit box. Further, a product scan 
can detect whether any product in the micro-warehouse has been recalled, expired, or 
is otherwise not suitable for use. Upon detecting such a product, the system refuses 

20 access to the micro-warehouse until an administrator removes the product or 
otherwise addresses the situation. 

The invention also provides a method of distributing a plurality of products 
from a micro-warehouse. The method may include fitting each product with a radio 
. frequency identification tag, positioning the plurality of products in the micro- 
25 warehouse, sensing opening and closing of the micro-warehouse door, scanning the 
plurality of products in the micro-warehouse upon sensing closing of the door to 
determine the number and type of products in the micro-warehouse, generating a 
message based on the number and type of products in the micro-warehouse, 
transmitting the message to a remote processor or server, and mamtaining an 
30 inventory in the server based on the message. 
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The method and system permit up-to-date information to be provided to the 
server which, in turn, can be connected to ordering and manufacturing information 
systems to ensure prompt re-stocking of the micro-warehouses. The system can be 
designed with multiple levels of access. For example, multiple micro-warehouses 
may be located within a secure room and a user badge may be encoded to permit a 
user to access the room only, a limited number of warehouses in the room, or all the 
warehouses in the room. 

As is apparent from the above, it is an advantage of the present invention to 
provide a method and system of identifying and distributing products. Other features 
and advantages of the present invention will become apparent by consideration of the 
detailed description and accompanying drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

In the drawings: 

FIG. 1 is a schematic diagram of a system embodying the invention. 

FIG. 2 is schematic diagram of the server and client controller of the system 
shown in FIG. 1 illustrating the architecture of the enterprise application of the server 
and the architecture of the software on the client controller. 

FIG. 3 is an illustration of the flow of products and information in a 
distribution system of the invention. 

FIG. 4a is a flowchart of the software's boot up routine of the invention. 

FIG. 4b is a flowchart of the software of the invention. 

DETAILED DESCRIPTION 

Before the invention is explained in detail, it is to be understood that the 
invention is not limited in its application to the details of the construction and the 
arrangements of the components set forth in the following description or illustrated in 
the drawings. The invention is capable of other embodiments and of being practiced 
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or being carried out in various ways. Also, it is to be understood that the phraseology 
and terminology used herein is for the purpose of description and should not be 
regarded as limiting. 

FIG. 1 illustrates a system 10 embodying the invention. The system 10 
5 includes two servers (maintenance and commerce) 1 1 and 12 that create and maintain 
user lists, perform inventory, account, ordering functions, and monitoring functions, 
such as microwarehouse status, monitoring temperature and other faults. Servers 1 1 
and 12 may communicate with a client (discussed below) using standard protocols 
such as TCP/IP, or other protocols over a network 13. The network 13 may be the 

1 0 Internet, a telephone network, a wireless network, power line carrier ("PLC") 

network, or combinations thereof. Servers 1 1 and 12 include standard hardware and 
operating system software (not shown). Running on top of the hardware and 
operating system software is a micro-warehouse ("MW") enterprise application 14. 
The MW enterprise application 14 accesses a profile database 15 that includes a 

1 5 registration module 1 6, an order history module 1 8, an account set-up module 20, and 
a stock request module 22. Each of the modules 16 - 22 is maintained for each client 
coupled to the server 12. The modules may be configured with web content designed 
to be accessible using protocols for the World Wide Web section of the Internet.' 

As best seen by reference to FIG. 2, the MW enterprise application 14 
20 performs numerous functions. Broadly, the MW enterprise application 14 controls 

the arrangement of the RFID user badges (discussed below), manages communication 
sessions with clients connected to the server 12, maintains an inventory of products 
for each client connected to the servers 1 1 and 12, checks inventory of the MW and 
other local MWs before ordering a product, manages security of communications, 
25 provides system adrninistration functionality, and monitors and maintains the health 
of clients connected to the servers. 

The registration module 16 provides part of the inventory functionality of the 
server 12 by providing access to information regarding the location of clients 
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connected to the server 12. In the invention, the clients take the form of MWs. The 
registration module also provides access to information regarding sales persons 
assigned to a particular MW and identification numbers for each MW. The 
registration module 16 may access a MW database 24. 

5 The order history module 1 8 provides a history of orders for each MW and 

product preferences for each MW. The account set-up module provides 
administrative screens for payment authorization, user information, and similar 
information. The stock request module 22 controls inventory replenishment based on 
usage and on specific customer requests and similar information. 

10 The server 12 also accesses a commerce engine 30 that uses information 

received from the client to generate orders that are delivered to the manufacturing 
irnrastructure (not shown) that produces products to be distributed using the system 
and method of the invention. The information may be used by marketing, customer 
relation management ("CRM"), billing, and other systems and functions. For 

1 5 example, the invention may be used in the distribution of life science research 

products such as enzymes, assays, cloning vectors, component cells, and the like. (Of 
course, a wide variety of non-biological products could be distributed using the 
invention.) The information provided by the server 12 is used in the manufacturing 
infrastructure to ensure proper production of products according to the demand for 

20 such products. As noted above, the server 12 may be coupled to a plurality of clients. 
An exemplary client in the form of a MW 35 is shown in FIGS. 1 and 2. While only 
one client is shown, the number of clients connected to the server 12 is limited only 
by the- server's internal capacity and the capacity of the network 13. 

The MW 35 may take the form of a refrigerated cabinet, a freezer, or other 
25 storage container. A secured storeroom, similar location, or other defined area could 
also be outfitted with a client controller and other components, as described herein, 
and be used to store products. As shown, the MW 35 includes a door 37, an electric 
actuated lock 39 and/or a proximity sensor 40, and an output device mat may take the 
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form of audio device or light 41. Other output devices such as a voice synthesis 
device, a display screen, and the like may also be used. The MW 35 is configured 
with an antenna array 43. The antenna array 43 is coupled to a client controller 45. In 
one embodiment, the invention may include an antenna with two vertically polarized 
5 array antennas. The antenna 43 is an RF receive and transmit device which 

communicates with a transponder device or tag (discussed in greater detail below). In 
one embodiment, the tag is a passive tag and powered by energy from the antenna. 

The MW 35 may include a specialized card reader 47 in the form of a 
magnetic card swipe device, an antenna, a fingerprint reader, or similar device. The 

10 specialized card reader 47 is coupled to the client controller 45 via a communication 
link 49. The MW 35 may also include an internal and ambient temperature sensor 55. 
If included, the temperature sensor 55 is preferably positioned such that it can sense 
the temperature of the interior of the MW 35. The temperature sensor 55 is coupled 
to the client controller 45 to provide temperature information to the client controller. 

15 Additional information may be provided to the client controller through optional input 
devices. The location of the MW 35 may be monitored by a global positioning 
system (GPS) device (not shown) plus inertial frame recognition for fine 
measurement and for interpolation between GPS satellite acquisitions. The voltage, 
frequency, and other characteristics of electrical supply lines may be monitored and 

20 provided to the client controller 45 by a power line monitoring device (also not 

shown). Additional input devices, such as cameras, microphones, sensors, etc., could 
be coupled to the client controller to monitor environmental and other conditions. 

The client controller 45 includes software to carry out several functions. The 
software included on the client controller 45 may be better understood by reference to 
25 FIG. 2. As shown, the client controller 45 includes an operating system 60. The 
operating system 60 is dependent on the type of processor used in the client 
controller. Preferably, the client controller 45 is an X86 single chip computer 
controller with a compatible operating system. If desired, the client controller 45 may 
be a consumer grade device such as a Palm Pilot personal digital assistant or Packet 
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PC device, and modified according to the teachings herein. Depending on the 
hardware used, the client controller 45 may be configured with a graphical user 
interface ("GUI") to facilitate interaction between the system 10 and its users. 

The client controller 45 also includes an I/O interface 62, which may take the 
5 form of an analogue-digital, digital-analogue converter, digital input/output (ADC, 
DAC, and DIO) interface. The interface 62 handles input from the electric actuated 
lock 39, input from the temperature sensor 55, output to the electric actuated lock 39, 
and input from optional monitoring devices such as the GPS and power line 
monitoring devices. 

10 In addition to the interface 62, the client controller 45 may have two other 

modules: an RFID user sensing subsystem 64 and a radio frequency data collector 
("RFDC") inventory interface 66. The EFTD user sensing subsystem 64 handles input 
and output to and from the specialized card reader 47. The RFDC inventory interface 
66 handles input and output from the antenna 43 and handles links or sessions 

15 between the MW 35 and severs 1 1 and 12. 

The client controller 45 includes software (not shown) which may incorporate 
the RFDC inventory interface 66 that reads the RFID signatures from tagged products 
(discussed below) placed inside the MW 35. The software may be implemented 
according to algorithms disclosed in International Publication No. W099/45495 and 

20 International Publication No. W099/45495, the disclosures of which are hereby 
incorporated by reference herein. The referenced publications teach identification 
systems that can identify a plurality of RFID tagged items using an interrogator. The 
interrogator sends signals from antennas and cooperates with passive, transponder 
RFID tags in such a way as to eliminate or reduce interference problems that are 

25 typically associated with reading RF signals from multiple devices. The system 10 
could also be implemented with active tags, although presently available active tags 
need to be improved so as to perform in the temperatures that the system is expected 
to operate within and at roughly the same cost and power consumption. 
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Before the system 10 may be implemented, one or more RFID access badges 
75 must be generated. Preferably, the RFID badges 75, as well as the other RFID tags 
(discussed below) are passive transponder tags such as the tags disclosed in the 
above-referenced international applications. Preferably, the RFID badges 75 are 
5 encoded with information from the account set-up module 20 based on digital 

signatures. In addition, it is preferred that the digital signatures encoded on the RFID 
badges 75 used by restocking services provide one-time access to a specific MW, and 
thereafter expire. The RFID access badges may be fixed on a carton of products 80. 
Alternatively, they may be delivered separately to the facility where the MW of 
10 interest is located. 

The carton of products 80 includes a plurality of individual products 90 each 
with an identification tag 95. Each identification tag 95 may be the same as an RFID 
badge 75, except that the digital signature on tag 95 will generally not expire. In one 
form of the invention, each tag 95 has a 16-bit identification code and a 72- bit item 
1 5 identification code. The 1 6-bit identification tag may be programmed with 

information such as the manufacturer of the product. The 72-bit item identification 
code is used to provide descriptive information regarding the product such as serial 
number, product type, date, lot number, and similar information. 

Once all the products 90 have been fitted with unique RFID tags 95, the 
20 products may be shipped in the carton 80 to a designated MW such as the MW 35. 

As shown in FIG. 3, the carton 80 is packed according to a fulfillment request that is 
based on either an initial order from a customer (not shown) or MW specific business 
rules followed by the server 12. The carton 80 may be fitted with RFID access badge 
75 or the RFID access badge 75 may be shipped separately to the location of the MW 
25 of interest. If fitted with an RFID access badge 75, the carton 80 may be shipped by a 
delivery service contracted to deliver the package to the MW 35. Once the carton is 
delivered, the recipient or user may use the RFED access badge 75 to open the door 37 
of the MW 35 by passing RFID access badge 75 in front of the reader 47. Client 
controller 45 reads the digital signature of the RFID access badge 75 and confirms 
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reading of the code by actuating a user feedback device such as a voice synthesis 
module or the light 41. Since, the server 12 provides a locally based user list to the 
client controller 45, the client controller 45 oversees authentication of the digital 
code read from the RPID access badge 75. Client controller 45 checks the 
5 authenticity of the read code by matching the code to the user list. Client controller 
45 may then optionally read the temperature sensors 55 and transmit temperature 
information to the server 11. Preferably, the temperature sensor is also read on a 
periodic basis, with the temperature information being transmitted to the server each 
time the temperature is read. Client controller 45 can also be programmed tp transmit 

1 0 temperature data if the temperature falls beneath or above a predetermined range. In 
many instances, it will be important to ensure that the temperature of the MW is 
within an appropriate range to store the products 90. If the temperature of the MW 35 
is within an appropriate range, and the user is authenticated, the client controller 45 
then actuates the lock 39 to open the door 37 (of course, the MW need not be 

15 equipped with the lock 39). If the temperature of the MW 35 is not within an 

appropriate range, then access to the MW may be prevented by mamtaining the lock 
39 in a closed state. This would allow a refrigerated unit associated with the MW to 
cool the interior space of the MW to a desired temperature before ambient air was 
allowed into the MW by opening of the door. This also provides for product integrity 

20 during power failure. 

Once the door 37 opens (which may be sensed by the proximity sensor 40), a 
communication session between the MW 35 and servers 12, which may be segmented 
based on appropriate events to optimize user response and network usage, begins. 
Having full access to the MW 35, the employee of a carrier or logistic service who 

25 delivered the carton 80 now proceeds to place the individual items 90 into the MW 
35. Once the carton of products 80 is empty, the delivery employee then closes the 
door 37, and removes the carton, if necessary. The proximity sensor 40 senses the 
closing of the door 37. The client controller 45 senses the status of the sensor. 
Preferably, the lock 39 (if used) resets automatically after being unlocked for a 

30 predetermined time, for example five (5) seconds. The user has that predetermined 
time to open the door. The RFDC inventory interface 66 is disabled once the door 37 
-10- 
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opens. When the door 37 closes, the RFDC inventory interface 66 is enabled and 
initiates a scan of the products placed within the MW 35. Upon completing the scan, 
the client controller 45 sends a change-in-inventory message 100 to the commerce 
server 12. To ensure integrity of the inventory change billed to the customer, the 
5 client controller 45 employs an integrity algorithm when the RFDC inventory 
interface 66 scans the MW 35. The algorithm is based on statistical information, 
historical information, and other factors including RF algorithms (frequency-hopping, 
etc.) and delay data. 

The MW 35 may be accessed by a customer at the MW location using a 

10 separate RFID badge 75 shipped directly to that customer. Alternatively, and as noted 
above, the reader 47 may be configured as a magnetic card swipe device, barcode, a 
fingerprint reader, or some similar device that controls access to the MW 35. 
Regardless of its exact configuration, the reader 47 reads the input from the customer 
and acknowledges reading of that input by Ughting the light 41. The client controller 

15 45 then sends an input signal to the server 12. The server 12 then conducts an 
authenticity review of the input. If an authorized input is received, the server 12 
sends an okay message to the MW 35. The client controller 45 may have the 
capability to authenticate the review as well. Once authentication takes place, the 
client controller 45 then opens the door 37 allowing the customer access to the interior 

20 of the MW 35. The customer then removes one or more products 90 from the interior 
of the MW and then closes the door 37. Once the door is closed, client controller 45 
scans the remaining products in the MW 35 and sends a message containing the 
missing products to the server 12. Identifying which products have been taken, the 
server 12 compares the previous inventory prior to opening, to the inventory of the 

25 missing items. From the comparison, the server 12 determines the missing items in 
the MW 35. The inventory information is then communicated to the commerce 
engine 30, which stores the information for future use for both marketing and 
inventory functions. Receipts for the used products can then be emailed or printed 
and shipped via regular mail to the customer at the MW location. Invoicing can also 

30 occur using electronic and standard mechanisms. 
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The inventory message can be used for other purposes as well. For example, 
the inventory message includes information regarding individual products. Therefore, 
the amount of time a particular product spends in any MW may be recorded by the 
server,' as well as the product's temperature history. If this time is recorded, it is also 
5 possible to compare the amount of time any particular product spends in a MW to a 
shelf life for that product. Temperature history can also be stored and compared to 
other data. If the shelf life is passed, then an expiration message, such as a pick list, 
may be generated and sent to the MW or an e-mail address of a user of the system to 
inform users of products that should be removed from the MW and not used. In 
10 addition, the inventory message may be used to determine the type of products in the 
MW 35. If any of the products present within the MW 35 are subject to a recall, the 
MW 35 may be placed in a "lock down" condition, whereby access to the MW is 
denied until an administrator or other authorized individual removes the recalled 
product or otherwise addresses the situation. 

15 FIG. 4a and 4b are flow charts of the software used in the invention. Once the 

client controller 45 is turned on in FIG. 4a at step 138, it executes a standard boot up 
routine at step 140. Part of the standard boot up process enables the software to 
automatically update itself. At step 142, a message is sent to the maintenance server 
1 1 to query the current version of the controller software. If the version on the server 

20 1 1 is the same as the version on the client controller 45, the client controller 45 

establishes a wait state as shown in step 152. If the version on the server 1 1 is newer 
than the version on the client controller 45, then the newer version is downloaded 
over the Internet, as shown at step 144. The newer version is loaded into the 
alternative pocket or partition and written to flash memory, as shown at step 146. 

25 Then the software is booted, as shown at step 148. A garbage collection routine 

clears the old version. A message packet accompanies each boot to the maintenance 
server, including version status and operating status. Each boot then requests a reload 
of the list of authorized users from the server 11 at step 150. The list is then reloaded 
at step 151. As shown in FIG. 4b at step 152, the client controller 45 then establishes 

30 the wait state of the system by initializing various variables or objects such as a 

USER, MSG 1, MSG 2, CNT1, TEMP 1, TEMP 2, and SOLENOIDS. In addition, 
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the client controller 45 initializes variables or objects SWITCHES, POWER, and 
LIGHT. Once initialization is complete, the unit is ready for user access. During this 
wait state, the client controller 45 performs periodic checks on the status of the MW 
35. When a customer approaches the MW and presents an RFED badge, the client 
5 controller 45 reads the user RFID badge at step 1 54 and checks the validity of the 

identification code read from the badge at step 158. If the code does not match a valid 
code, an invalid user message is generated at step 162. The message may be 
displayed on an output device (not shown). If an optional lock is installed on the door 
of the MW 35, the client controller 45 then opens the solenoids in the lock on the MW 

10 35, as shown at step 166, if the code is valid. An internal timer is then started, as 
shown at step 170. In one embodiment of the invention, the proximity sensor 40 is 
used to detect opening of the door 37 and the status of the door. Once the door opens, 
the proximity sensor 40 switches its status. At step 174, the client controller 45 
checks to see if the door has been opened by reading the status of the proximity sensor 

15 40. If the proximity sensor 40 has not changed status, the client controller 45 will 
continue to check for a predetermined amount of time, as shown at step 178. If the 
predetermined amount of time is exceeded, the solenoids are closed (step 182), which 
locks the lock 39, a timeout error message is generated (step 184), and the client 
controller 45 returns to the initial state, as shown at step 186. 



20 If the door 37 is opened within the predeterrnined amount of time (currently 

set through practice at five (5) seconds), a second timer is started, as shown at step 
190. The client controller 45 then records the internal temperature of the MW 35 at 
step 194 and then checks to see if the door 37 has been closed at step 200. The client 
controller 45 continues to check for closing of the door for a predeterrnined amount of 

25 time, as shown at step 204. If the predetermined amount of time expires, a close door 
message is generated as shown at step 208 and steps 190 - 204 are re-executed. 

Once the door 37 is closed, the client controller 45 closes the solenoids, as 
shown at step 212. The client controller 45 then confirms that the door 37 is closed at 
step 216 and performs an inventory scan at step 220. The data from the inventory 
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scan is then sent to the server 12, as shown at step 224. The client controller 45 then 
returns to the initial state (step 186). 

In another embodiment, the system utilizes a defined area to enclose the 
tagged products rather than a cabinet. The defined area uses an access point to serve 
5 as its entryway. The products within the area are fitted with identification tags and 
specifically positioned in the area to be recognized by the RFDC inventory interface. 
Product scans begin when a sensor senses a user passing through the access point. 
The access point is controlled by a processor, such as the client controller 45, and is 
able to restrict access to the area and products, if necessary. 



10 As can be seen from the above, the invention provides a method and system 

for distributing products. Various features and advantages of the invention are set 
forth in the following claims. 
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CLAIMS 

What is claimed is: 

1 . A method of distributing a plurality of products from a cabinet having a door, 
the method comprising: 

fitting each product with a radio frequency identification tag; 

5 positioning the plurality of products in the cabinet; 

sensing opening and closing of the cabinet door; 

scanning the plurality of products in the cabinet upon sensing closing of the 
cabinet door to determine the number and type of products in the cabinet; 

generating a message based on the number and type of products in the cabinet; 

10 transmitting the message to a server; and 

mamtaining an inventory in the server based on the message. 

2. A method as claimed in claim 1 , further comprising: 
reading a code on a user badge; 
acknowledging having read the user badge; 

1 5 deterrrumng the authenticity of the code read from the user badge; and 

opening the cabinet if the code read from the user badge is authentic. 

3. A method as claimed in claim 2, further comprising closing the cabinet after a 
predetermined amount of time. 

4. A method as claimed in claim 2, wherein the step of determining authenticity 
20 is done at the server. 
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5. A method as claimed in claim 1 , wherein the inventory is maintained in the 
micro-warehouse controller. 

6. A method as claimed in claim 2, further comprising actuating an output device 
if the code read from the user badge is authentic. 

5 7. A method as claimed in claim 1 , further comprising sensing the temperature of 
the cabinet and transmitting the temperature to the server. 

8. A method as claimed in claim 7, further comprising denying access to the 
cabinet until the temperature reaches a predetermined level. 

9. A method as claimed in claim 1, further comprising tracking the rime each of 
10 the plurality of products spends in the cabinet. 

10. A method as claimed in claim 9, further comprising comparing the time each 
of the plurality of products spends in the cabinet to a shelf life for each of the plurality 
ofproducts. 

11. A method as claimed in claim 10, further comprising generating a pick list of 
15 products for each product that has spent a time in the cabinet that is greater than the 

shelf life of that product. 

12. A method as claimed in claim 1, further comprising scanning the products in 
the cabinets and determining whether any of the products have a recall status. 

13. A method as claimed in claim 1 , wherein the message contains information 
20 regarding the status of individual products. 

14. A method as claimed in claim 13, wherein the status of individual products 
includes product's type, temperature history, and time spent in the micro-warehouse. 

15. A method as claimed in claim 2, wherein the server uses a self-updating boot 
up procedure, the procedure comprising: 

25 receiving a message containing a most recent software version number; 
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comparing a software version number currently used to the most recent 
software version number; 

downloading the most recent software version if versions differ when 
compared; 

5 writing the downloaded software to memory; and 

booting the downloaded software. 

16. A method as claimed in claim 15, further comprising: 

requesting an updated user list; and 

receiving the updated user list. 

10 17. A method as claimed in claim 1 6, wherein the inventory change is calculated 
in the micro-warehouse controller and a message generated containing this change is 
sent to the server. 

18. A method as claimed in claim 1, wherein the inventory is calculated based on 
a first message generated from a scanning of the plurality of products made prior to 

15 sensing opening of the cabinet door and a second message generated from a scanning 
of the plurality of products made after sensing closing of the cabinet door. 

19. A system for distributing a plurality of products, each product having a radio 
frequency tag, the system comprising: 

a radio frequency user badge having a code; 

20 at least one micro-warehouse, the micro-warehouse having 

an output device, 

a door with a proximity sensor, 

an antenna mounted on the micro-warehouse, and 
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a controller coupled to the proximity sensor and the antenna, the 
controller operable to read the code, to activate the output device after reading 
the code on the user badge, to scan the plurality of products and determine the 
identity of each of the products, and to create a message including the identity 
5 of each of the products; and 

a server coupled to the controller to receive the message. 

20. A system as claimed in claim 19, further comprising a temperature sensor 
mounted in the micro-warehouse and coupled to the controller. 

21. A system as claimed in claim 19, wherein the system includes a plurality of 
1 0 micro-warehouses and the server includes a micro-warehouse database. 

22. A system as claimed in claim 19, wherein the server includes a registration 
module. 

23. A system as claimed in claim 19, wherein the server includes an order history 
module. 

15 24. A system as claimed in claim 19, wherein the server includes an account 
management module. 

25. A system as claimed in claim 19, wherein the server includes a stock request 
module. 

26. A system as claimed in claim 19, wherein the controller uses a self-updating 
20 boot up procedure, the procedure comprising: 

receiving a message from the server containing software version number; 

comparing software version number currently used to the most recent software 
version number; 

downloading the most recent software version if versions differ when 
25 compared; 
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writing downloaded software to memory; and 
booting the downloaded software. 

27. A method as claimed in claim 26, further comprising: 
requesting an updated user list; and 

receiving updated user list. 

28. A method of ordering a plurality of products from a defined area without 
requiring manual input to a computer, the method comprising: 

fitting each product with an identification tag; 

positioning the plurality of products in the defined area; 

scanning the plurality of products in the defined area to determine the number 
and type of products in the defined area; 

generating a message based on the number and type of products in the defined 

area; 

transmitting the message to a server; and 

maintaining an inventory in the server based on the message. 

29. A method as claimed in claim 28, further comprising: 
reading a code on a user badge; 
acknowledging having read the user badge; 

determining the authenticity of the code read from the user badge; and 

providing access to the defined area if the code read from the user badge is 
authentic. 
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30. A method as claimed in claim 29, providing access to the defined area 
includes providing access for a predetermined amount of time. 

31. A method as claimed in claim 29, wherein the step of determining authenticity 
is done at the server. 

32. A method as claimed in claim 30, further comprising actuating an output 
device if the code read from the user badge is authentic. 

33. A method as claimed in claim 28, wherein the inventory is calculated based on 
a first message generated from a first scanning of the plurality of products and a 
second message generated from a second scanning of the plurality of products. 



-20- 



WO 02/35432 



PCT/US01/32230 



AMENDED CLAIMS 

[received by the International Bureau on 27 February 2002 (27.02.02); 
new claims 34-36 added; remaining claims unchanged (1 page)] 



34. A method of distributing a plurality of products from a defined area, the method 
comprising: 

providing each product with an identification tag; 
positioning the plurality of products in the defined area; 
sensing access to and exiting of the defined area; 

scanning the plurality of products in the defined area upon sensing exiting to the 
defined area to determine the number and type of products in the defined area; 

generating a message based on the number and type of products in the defined area; 

transmitting the message to a server; and > 

mamtaining an inventory in the server based on the message. 

35. A method of distributing a plurality of products from a defined area, the method 
comprising: 

providing each product with an identification tag; 
sensing access to and exiting of the defined area; 

scanning the plurality of products in the defined area upon sensing exiting to the 
defined area to determine the number and type of products in the defined area; 

generating a message based on the number and type of products in the defined area; 

transmitting the message to a server; and 

maintaining an inventory in the server based on the message. 

36. A system for distributing a plurality of products, each product having a radio-, 
frequency tag, the system comprising: 

a radio frequency user badge having a code; 
at least one defined area, the defined area having 
an output device, 

a proximity sensor for sensing access to and exiting of the defined area, 
an antenna mounted on the defined area, and 

a controller coupled to the proximity sensor and the antenna, the controller . 
operable to read the code, to activate the output device after reading the code on the user 
badge, to scan the plurality of products and detennine the identity of each of the products, 
and to create a message including the identity of each of the products; and 
a server coupled to the controller to receive the message. 
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SOFTWARE FLOW 
INITIAL STATE: USER - NONE 

MSG 1 =0 MSG 2 = 0 
CNTR 1=0 

TEMP 1 = TTEMP 2 = 0 
SOLENOIDS = 0 (CLOSED) 



WO 02/35432 



PCT/US01/32230 



5/5 

SOFTWARE aoW 



INITIAL STATE : USER = NONE 

MSG 1=0 MSG2=0 
CNTR1 = 0 

T£MP1=TTEMP2 = 0 
SOLENOIDS = 0 (CLOSED) 
SWITCHES = 1 (CLOSED) 

POWER b 1 (STATUS * ON) 
LIGHT - 0 (OFF) 




SEND DATA TO 
SERVER 



^ Z „ CLOSE 
SOLENOIDS 
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